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1.0 Scope of Manual 


This specification describes the key features, specification 
summary, physical characteristics, environmental 
characteristics, functional description, electrical interface, 
recommended mounting configuration, interface description, 
electrical description, timing requirements, host address 
decoding, register description, command description, operations 
description and error reporting for the Conner Peripherals 
model CP3104. 
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2.0 Key Features 


The CP3104 is a high performance 3.5 inch 104.9 megabyte 
(formatted) disk drive designed to operate on an IBM® PC AT or 
equivalent in either translate or native modes featuring 1:1 
interleave. Because the drive contains the Task File within its 
control logic, it requires a simplified adapter board to operate. 
Conner Peripherals has developed an adapter board to be used 
in conjunction with the drive on an AT or equivalent system. 
The logic and a description of this adapter board can be found in 
appendix A of this document. 


Key Features include: 


1:1 Interleave 

32K Buffer 

Read Look Ahead Capability 
AC Hysterisis on Interface 

7 Byte ECC on Data Block 

2 Byte CRC on Header Block 


High performance rotary voice coil actuator with 
embedded servo system. 


Two of seven run length limited code. 
Internal air filtration system 


Automatic actuator latch against inner stop upon power 
down. 
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e Microprocessor controlled diagnostic routines that are 
automatically executed at start up. 


e Automatic error correction and retries. 
¢ Block size 512 bytes. 
¢ Emulates Task File and supports additional commands. 


e Up to two drives may be daisy chained on this interface. 
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3.0 Specification Summary 


3.1 Capacity 


Formatted Mbytes 


104 Mbytes 





3.2 Physical Configuration 


Actuator Type 
Number of Disks 
Data Surfaces 
Data Heads 
Servo 


Tracks per Surface 

Track Density (TPIl) 

Formatted Track Capacity (Bytes) 
Bytes per Block 

Blocks per Drive 

Blocks per Track 





Rotary Voice-Coil 


Embedded 
776 

1150 
16,896 
512 
204,864 
33 
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3.3 Performance 


| Seek anes: Track to Track: 8.0 ms | 


Average: 25.0 ms 
Maximum: 45.0 ms 





Average Latency 8.4ms 
Rotation Speed (+0.1%) 3575 RPM 
Controller Overhead 1.0 ms 


Data Transfer Rate (To/From Media) 1.25 MByte/second 
Data Transfer Rate (To/From INTF) 3.75/4.75 
MByte/second 
Start Time (Power Up) Typical: 15 seconds 
(0 RPM — Ready) Maximum: 20 seconds 


Stop Time (Power Down) Typical: 15 seconds 

Maximum: 20 seconds 
Start/Stop Cycles 10,000 minimum 
Interleave : 
Buffer Size 





I The timing is measured through the interface with the drive 
operating at nominal DC input voltages. The timing also 
makes the following assumptions: 

¢ BIOS and PC system hardware dependency 
have been subtracted from timing 
measurements. 

¢ The drive is operated using its native drive 
parameters. 

2 The average seek time is determined by averaging the seek time 
for a minimum of 1000 seeks of random length over the surface 
of the disk. 
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3.4 Read/Write 


Interface Task File 
Recording Method 2 of 7 RLL code 


Recording Density (ID) 23,441 bits per inch 
Flux Density (ID) 15,627 flux reversals per inch 





3.5 Power Requirements (typical) 


Lot +12VDC+5% |+5VDC+5% POWER 


Read/Write Mode 350 ma 
Seek Mode 260 ma 


Ready Mode 175 ma 
Spin-Up Mode 1800 ma 
(7 seconds) 





Maximum noise allowed (DC to 1 MHZ, with equivalent resistive 
load): +12V DC: 1%, +5V DC: 2%. 


Read/Write mode occurs when data is being read from or 
written to the disk. 


Seek Mode occurs while the actuator is in motion. 
Ready Mode occurs when the drive is not reading, writing, or 
seeking. The motor is up to speed and DRIVE READY condition 


exists. Actuator is residing on last accessed track. 


Spin up Mode current draw is for 7 seconds max. 
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3.6 Physical Characteristics 


Outline Dimensions + .010" | 1.62" x 4.00" x 5.75" (with shock frame) 


Weight 1.8 pounds 
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4.0 Environmental Characteristics 


4.1 Temperature 


Operating 5°C to 55°C 


Non-operating -40°C to 60°C 
Thermal Gradient 20°C per hour maximum 





4.2 Humidity 


Operating 8% to 80% non-condensing 
Non-operating 8% to 80% non-condensing 
Maximum Wet Bulb 26°C 





4.3 Altitude (relative to sea level) 


Operating -200 to 10,000 feet 
Non-operating (maximum) 40,000 feet 


4.4 Reliability and Maintenance 





1 
MTBF 50,000 hours (POH) 
MTTR 10 minutes typical 
Preventive Maintenance None 


Component Design Life 5 years 
Data Reliability <1 non-recoverable error in 
10 12 bits read 





I population minimum of 100 units 
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4.5 Shock and Vibration 


Shock 1/2 sine pulse, 11 ms duration 

Vibration Swept sine, 1 octave per minute 
1 

Nonoperating shock 50 G's 


Nonoperating vibration 
5-62 Hz .020" double amplitude 
63-400 Hz 4 G's (peak) 


Operating Shock / 5 G's (without non-recoverable 


1 errors) 

Operating Vibration 
5-22 Hz .010" double amplitude 
23-500 Hz .25 G's peak (without 

non-recoverable errors) 





4.6 Magnetic Field 


The disk drive will meet its specified performance while 
operating in the presence of an externally produced magnetic 
field under the following conditions: 


0 to 700Khz 6 gauss maximum 
700Khz to 1.5 Mhz 1 gauss maximum 


4.7 Acoustic Noise 






The sound pressure level will not exceed 40 dBA at a distance of 


1 meter from the drive. 
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4.8 Safety Standards 


Conner Peripherals disk drives are designed to comply with 
relevant product safety standards such as: 


UL 478, 5th edition, Standard for Safety of Information 
Processing and Business Equipment, and 


UL 1950, Standard for Safety of Information Technology 
Equipment 


CSA 22.2 #154, Data Processing Equipment and 
CSA 22.2 #220, Information Processing and Business 
Equipment. 


IEC 435 Safety Requirements for Data Processing 
Equipment, 

IEC 380, Safety of Electrically Energized Office 
Machines, and 

IEC 950, Safety of Information Technology Equipment 
Including Electrical Business Equipment. 


VDE 0805 Equivalent to IEC 435, 


VDE 0805 TIEL 100, Equivalent to IEC 950, and 
VDE 0806, Equivalent to IEC 380. 
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5.0 Functional Description 


The CP3104 contains all necessary mechanical and electronic 
parts to interpret control signals, position the recording heads 
over the desired track, read and write data, and provide a 
contaminant free environment for the heads and disks. 


5.1 Read/Write and Control Electronics 


One integrated circuit is mounted within the sealed enclosure in 
close proximity to the read/write heads. Its function is to 
provide one of eight head selections, read preamplification, and 
write drive circuitry. 


The single microprocessor controlled circuit card provides the 
remaining electronic functions which include: 


Read/Write Circuitry 
Rotary Actuator Control 
Interface Control 

Spin Speed Control 
Dynamic Braking 


At power down the heads are automatically retracted to the 
inner diameter of the disk and are latched and parked on a 
landing zone that is inside the data tracks. 


5.2 Drive Mechanism 


A brushless DC direct drive motor rotates the spindle at 3575 
RPM. The motor/spindle assembly is dynamically balanced to 
provide minimal mechanical runout to the disks. A dynamic 
brake is used to provide a fast stop to the spindle motor and 
return the heads to the landing zone when power is removed. 
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5.3 Air Filtration System 

The head-disk assembly is a sealed enclosure with an integral 
0.3 micron filter which maintains a clean environment for the 
heads and disks. 

5.4 Head Positioning Mechanism 


The eight read/write heads are supported by a mechanism 
coupled to the voice coil actuator. 


5.5 Read/Write Heads and Disks 


Data is recorded on four 95mm diameter disks through eight 
3370 type heads. 


5.6 Error Correction 

The CP3104 performs internal error correction. The error 
correction polynomial is capable of correcting one error burst 
with a maximum of 8 bits per 512 byte block. The following 
polynomial is used: 


ECC: X56+X52+X50+X43+X41+X34+X30+X26+X8+1 
CRC: X16+X12+X5+1 
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5.7 Customer Options 


There are four jumper options available for configuration, 
-HSP, -C/D, -DSP, and -ACT. 


-HSP, when jumpered connects a ground to -HOST SLV/ACT 
signal (pin 39 of J2) on the interface for those systems that 
require the slave drive to provide -SLAVE PRESENT signal 
from the slave drive to a two drive. system. 


-C/D is the address jumper. When jumpered, the master or C 
drive is selected. 


-DSP, when jumpered, indicates to the drive that a slave is 
present. In a two drive system, this jumper option must be 
installed in the master, or C drive. 


The last jumper, -ACT, connects the active signal to the -HOST 
SLV/ACT signal (pin 39 of J2) on the interface. This signal 
provides the capability to drive an external LED. An external 
current limiting resistor is required. There is another way to 
connect the drive LED. J4, pins 1 and 2, provide both an open 
collector drive signal and a current limiting resistor connected 
on the other end to +5V. 
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The following table shows what the jumper settings should be 
for various system configurations. 


Jumper 
Configuration 1 Drive 1 Drive Master 2 Drive Slave 


ACT 
C/D 
HSP 
DSP 









Note 1: In a two drive system, it is possible to drive one LED with both 
drives. An external current limiting resistor is required. The -ACT 
and HSP signals both use pin 39 of J2,-HOST SLV/ACT. They 
are therefore mutually exclusive. 


Note 2: If the model CP3104 is operating as a slave drive connected to 
a Master drive that requires that the signal, -DRIVE SLAVE 
PRESENT be supplied from the slave drive via the interface signal - 
HOST SLV/ACT, then this jumper must be installed. If this jumper 
is installed, the -ACT jumper must not be installed because they both 
use pin 39 of J2. 
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HDA CABLE 


SERAIL IN/OUT LED DRIVE 


CAPABILITY \ 


SN 40 PIN 
S2ZNe CONNECTOR 





,-- SEE DETAIL A 


Figure 1. Customer Options 
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6.0 Electrical Interface 
6.1 Power Connector 


The CP3104 has a 4 pin DC power connector (J3) mounted on 
the PCB. For the location and pin assignments for J3 see figure 
1. The recommended mating connector is AMP part number 
1-480424-0 utilizing AMP pins part number 350078-4 or 
equivalent. 


6.2 Cabling 


Connect the power cable to J3. Connect the Task File interface 
cable to J2. 


6.3 Diagnostic Routines 


The microprocessor performs diagnostics upon application of 
power. If an error is detected the CP3104 will not come ready. 


= 
we) 
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7.0 Recommended MountingConfiguration 


The CP3104 drive is designed to be used in applications where 
the unit may experience shock and vibrations at greater levels 
than larger and heavier disk drives. 


The features which allow greater shock tolerance are the use of 
rugged media and shock mounts. To take full advantage of the 
shock mounts, it is necessary to provide a minimum of 0.1 inch 
clearance on both the top and sides of the drive. This clearance 
allows for movement of the drive during acceleration. The drive 
may be mounted in any attitude. 


7.1 Mechanically Isolated Mounting Points 


Ten base mounting points are provided to the customer. Each 
mounting point is mechanically isolated from the head/disk 
assembly. The drive is mounted using 6-32 screws; 1/8" max. 
insertion for the sides, and 1/4" max. insertion for the bottom. 
The system integrator should allow ventilation to the drive to 
ensure reliable drive operation over the operating temperature 
range. 
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NOTE: DIMENSIONS DO NOT INCLUDE SHOCK CLEARANCES 
Figure 2. Mounting Configuration 
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8.0 Interface Description 
8.1 Physical Description 
The CP3104 user interface is a 40 conductor cable with Molex 
P/N 15-47-3401 female header or equivalent. The interface 
allows up to two drives to be daisy chained together. The 
maximum cable length is two feet. 
8.2 Connector 
The CP3104 connector is a 40 conductor connector which 


consists of two rows of 20 male pins on 100 mil centers. The 
header part number is Molex P/N 7723-40A587, or equivalent. 


Revision I.3 -19- 


9.0 Electrical Description 


9.1 Signal Levels 


All signal levels are TTL compatible. A logic "1" is > 2.0 Volts. A 
logic "0" is from 0.00 Volts to .70 Volts. The drive capability of 
each of the inbound signals is described in section 9.3. 


9.2 Signal Conventions 


The interface between the drive adapter and the drive is called 
the Host Interface. The set of registers in the I/O space of the 
Host is known as the Task File. 


All signals on the Host Interface shall have the prefix HOST. 
All negatively active signals shall be further prefixed with a "-" 
designation. All positive active signals shall be prefixed with a 
"+" designation. Signals whose source are the Host, are said to 
be "outbound" and those whose source is the drive, are said to be 


"inbound". 
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9.3 Pin Descriptions 


The following table describes all of the pins on the Task File 
Interface (J1). 


PIN SIGNAL _| PIN | SIGNAL 


01 —-HOST RESET 02 | GND 

03 +HOST DATA 7 04 | +HOST DATA8 
05 +HOST DATA 6 06 | +HOST DATA9 
07 | +HOST DATAS5 08 | +HOST DATA 10 
09 +HOST DATA 4 10 | +HOST DATA 11 
11 +HOST DATA 3 12 | +HOST DATA 12 
13 +HOST DATA 2 14. | +HOST DATA 13 
15 +HOST DATA 1 16 | +HOST DATA 14 
17. | +HOST DATAO 18 | +HOST DATA 15 


19 | GND 20 | KEY 
21 RESERVED 22 | GND 
23. | -HOST IOW 24 | GND 
25 | —-HOSTIOR 26 | GND 
27 RESERVED 28 | +HOST ALE 
29 RESERVED 30 | GND 
31 +HOST IRQ14 32 | —HOST 1016 


33 +HOST ADDR 1 34 | —HOST PDIAG 
35 +HOST ADDR 0 36 | +HOST ADDR 2 
37 | -HOST CSO 38 | -HOST CS1 

39 | -HOST SLV/ACT 40 | GND 
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Signal Name 


-HOST RESET 


GND 


+HOST DATA 0-15 


GND 


KEY 


RESERVED 


GND 


-HOST IOW 


GND 


Dir 
O 


V/O 


N/C 


N/C 


Pin 


01 


02 


03-18 


19 


21 


22 


23 


24 


Description 


Reset signal from the Host 
system which is active low. 


Ground between the drive and 
the Host. 


16 bit bi-directional data bus 
between the host and the drive. 
The lower 8 bits, HDO—HD7, are 
used for register & ECC 
access. All 16 bits are used for 
data transfers. These are tri- 
state lines with 24 mA drive 
capability. 


Ground between the drive and 
the Host. 


An unused pin clipped on the 
drive and plugged on the cable. 
Used to guarantee correct 
orientation of the cable. 


A pin reserved for future use. 


Ground between the drive and 
the host. 


Write strobe, the rising edge of 
which clocks data from the host 
data bus, HDO through HD15, 
into a register on the drive. 


Ground between the drive and 
the host. 
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iqnal 


-HOST iOR 


GND 


RESERVED 
+HOST ALE 
GND 


+HOST IRQ14 


-HOST 1016 
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E 


25 


26 


27,29 
28 
30 


31 


32 


Descripti 


Read strobe, which when low 
enables data from a register on the 
drive onto the host data bus, HDO 
through HD15. The rising edge 

of -HOST IOR latches data from 
the drive at the host. 


Ground between the drive and 
the host. 


Not Connected. 
Not Connected. 
Ground between drive and host. 


interrupt to the Host system, 

enabled only when the drive is 
selected, and the host activates 

the -IEN bit in the Digital Output 
register. When the -IEN bit is 

inactive, or the drive is not 

selected, this output in a high 
impedance state regardless of the state 
of the IRQ bit. The interrupt is set when 
the IRQ bit is set by the drive CPU. IRQ 
is reset to zero by a Host read of the 
Status register or a write to the 
command register. This signal is a 
tri-state line with 8 ma drive capacity. 


Indication to the Host system 
that the 16 bit data register has 
been addressed and that the 
drive is prepared to send or 
receive a 16 bit data word. This 
line is tri-state line with 24 mA 
drive capacity. 
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Signal Name 


-HOST PDIAG 


+HOST A0,A1,A2 


-HOST CSO 


-HOST CS1 


Dir Pin 
| 34 
O 35,33,36 
O 37 
O 38 


D ription 


Passed diagnostic. Output by 

the drive if it is in the slave mode 

(-C/D not installed) . Input to the drive if 
it is in the master mode (-C/D 

installed). This low true signal indicates 
to a master that the slave has passed its 
internal diagnostic command. This line 
is a tri state line with 24 mA drive 
capability. 


Bit binary coded address used 
to select the individual registers 
in the task file. 


Chip select decoded from the 
host address bus. Used to 
select some of the Host 
accessible registers. 


Chip select decoded from the 
Host address bus. Used to 
select three of the registers in 
the Task File. 
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Signal Name 
-HOST SLV/ACT 


GND 
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— 


vu 
5 


39 


40 


D ription 


Signal from the drive used either 
to drive an active LED whenever 
the disk is being accessed or as 
an indication of a second drive 
present. (See the Customer 
Options section for further 
information.) When jumpered 
as -ACTIVE, this signal is active 
low when the drive is busy and 
has a drive capability of 20 ma. 
When jumpered as -SLAVE 
PRESENT signal, it is an 
indication of the presence of a 
second drive when low. In this 
state, it has a drive capability of 
10 mA open drain. 


Ground between the drive and 
the host. 
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10.0 Timing Requirements 


10.1 Host Interface Timing 
(All times are in ns) 


Symbol Parameter Min Max 
CS16L HCSO low to IOCS16 low 20 
CS16H IOR/IOW high to IOCS16 high 60 
RDTA IOR low to HD (0:15) valid 60 
RDLHD IOR high to HD (0:15) invalid 0 20 
RDTRI IOR high to HD (0:15) tri-state 20 
WDS IOW setup to HD (0:15) high 40 
WDHLD IOW hold from HD (0:15) high 10 
RWPULSE IOR/IOW pulse width 80 
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11.0 Host Address Decoding 


The Host addresses the drive using programmed I/O. This 
method requires that the desired register address be placed on 
the three Host address lines HA2-HAO, a proper chip select is 
asserted and a read or write strobe, (HOST IOR/-HOST IOW), 
given to the chip. 


The Host generates two independent chip selects on the 
interface. The high order chip select, -HOST CS1, is valid only 
when the Host is accessing the three separate register 
addresses; alternate status register, digital output register, and 
drive address register. The low order chip select, -HOST CSO, is 
used to address all other registers. 


The Host data bus 15-8 is only enabled when 1016 enable is 
active and the Host is addressing the data register for 
transferring data and not the ECC bytes which are only 
transferred if the operation is a read or write long. 
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The following I/O map defines all of the register addresses and 
functions for these I/O locations. A description of each register 
follows. 


No Operation No Operation 
Invalid Address Invalid Address 
High Impedance Not Used 

High Impedance Not Used 

Data Register Data Register 

Error Register Write Precomp Register 
Sector Count Sector Count 
Sector Number Sector Number 
Cylinder Low Cylinder Low 
Cylinder High Cylinder High 

SDH Register SDH Register 
Status Register Command Register 
Alt.Status Register | Dig Output Register 
Drive Addr. Register| Not Used 


a et ete tet it OOO OO OOK OK 
= =| ss - OO = OOO mM MK 
=—O0O-—-" O =|" O =|" O =" OK K mM 


; 
1 
1 
0 
0 
0 
0 
0 
0 
0 
0 
1 
1 
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xX = don't care 


I These 1/O port addresses are listed for programmer reference. 

They are a function of I/O decoding in the Host Adapter, such as the 
Conner AT Adapter Card shown in Appendix A. These I/O 
addresses are required for compatibility with typical AT BIOS. 
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12.0 Register Description 


In the following register descriptions, unused read bits should 
be treated as "don't cares", and unused write bits should be 
written as zeroes. 


12.1 Data Register 
-HOST CSO, address 0, R/W 


The Data register is the register through which all data is 
passed on Read and Write commands. It is also the register to 
which the sector table is transferred during Format commands 
and the data associated with the Identify command is 
transferred. All transfers are high speed 16 bit I/O operations 
except for ECC bytes transferred during R/W long commands, 
which are slower 8 bit operations that occur after the transfer of 
the data. 


Data is stored on the disk with the Least Significant Byte first, 
then the Most Significant Byte for each word. This is important 
to remember when testing the ECC circuitry. 


12.2 Error Register 


-HOST CSO, address 1, Read only 


This Error register contains status from the last command 
executed by the drive. The contents of this register are only 
valid when the error bit (ER) is set in the Status register, unless 
the drive has just powered up or completed execution of its 
internal diagnostic,in which case the register contains a status 
code. The error bits in the register are defined below. The 
status codes are discussed later in the description of the 
DIAGNOSTIC Command. 
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_b7 | bo | bs | bs | bs | be | bi | b0 | 
= _- | 


pak | unc | - | IDNF ABRT | TKO 


where: 


BBK indicates that a bad block mark was detected in the 
requested sector's ID field. A bad block is not created in the 
factory, but only when requested in the Format command. 


UNC indicates that an non correctable data error has been 
encountered. 


IDNF indicates that the requested sector's ID field could not be 
found. 


ABRT indicates that the requested command has been aborted 
due to a drive status error (not ready, write fault, etc.) or 
because the command code is invalid. 


TKO indicates that track 0 has not been found during a 
Recalibrate command. 


-- not used. These bits are reset to zero. 
12.3 Write Precompensation 
HOST CSO, address 1, Write only 
An 8 bit register used in previous disk drives to define the 
cylinder at which precompensation would begin. This register is 


used for other purposes for the CP3104. Also see the description 
of the Set Buffer command. 
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12.4 Sector Count 


-HOST CSO, address 2, R/W 


The sector count defines the number of sectors of data to be read 
or written. If the value in this register is zero, a count of 256 
sectors is specified. This count is decremented as each sector is 
read such that the register contains the number of sectors left to 
access in the event of an error in a multi-sector operation. 

The contents of this register define the number of sectors per 
track when executing an Initialize Drive command. 


12.5 Sector Number 


-HOST CSO, address 3, R/W 


This register contains the starting sector number for any disk 
access. At the completion of each sector, and at the end of the 
command this register is updated to reflect the last sector read 
correctly, or the sector on which an error occurred. During 
multiple sector transfers, this register is updated to point at the 
next sector to be read/written if the previous sector's operation 
was successful. 


12.6 Cylinder Low 


-HOST CSO, address 4, R/W 


The Cylinder Low register contains the low order 8 bits of the 
starting cylinder number for any disk access. At the completion 
of each sector, and at the end of the command, this register is 
updated to reflect the current cylinder number, as described 
above in the Sector Number description. 
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12.7 Cylinder High 

-HOST CSO, address 5, R/W 
The Cylinder High register contains the two high order bits of 
the starting cylinder number for any disk access. At the 
completion of each sector, and at the end of the command, this 
register is updated to reflect the current cylinder number. As 
described above in the Sector Number description. 
12.8 SDH Register 

-HOST CSO address 6, R/W 


This register contains the drive and head numbers, as defined 
below: 


| b7 | bo | os | ba | bs | be | bt | bo 
rsvp] o | 1 [orv] HEAD 


where: 

RSVD this bit is used by the Host. 

DRV is the binary encoded drive select number. When this bit 
is reset, the master drive is selected, and when this bit is set, the 
slave drive is selected. 


HEAD is the four bit binary encoded head select number. 


At the completion of each sector, and at the end of the command, 
this register is updated to reflect the currently selected head. 
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12.9 Status Register 


-HOST CSO, address 7, Read only 


This register contains the drive/controller status. The contents 
of this register are updated at the completion of each command. 
If the busy bit is active, no other bits are valid. The Host 
reading this register when an interrupt is pending is considered 
to be the interrupt acknowledge, and any pending interrupt is 
therefore cleared whenever this register is read. 


The bits in this register are defined below: 


| b7 | be | bs | bs | bs | be | bt | bo | 
| ora |corr} 10x | ERR | 


where: 


BSY is the busy bit, which is activated whenever the drive has 
access to the Task File registers, and the Host is locked out from 
accessing the Task File. This bit is activated under the following 
circumstances: 


1) At activation of the HOST RESET pininthe interface, or 
at activation of the software bit in the digital output 
register. 


2) Immediately upon Host write of the Command 
register with a Read, Read Long, Read Buffer, Seek Recall, 
Initialize Drive Parameters,Verify, Identify, or Diagnostic 
command. 
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3) Immediately following transfer of 512 bytes of data after 
Host write of the command register with a Write, 
Format Track, or Write Buffer command, or 512 bytes of 
data and the seven ECC bytes after a Host write of the 
command register with a Write Long command. When 
BSY is active, any HOST read of a Task File register is 
inhibited and the Status register is read instead. 


DRDY is the drive ready indication. When there is an error, 
this bit is not changed until the Status register is read by the 
Host, at which time the bit again indicates the current readiness 
of the drive. This bit will be inactive at power up and remain 
inactive until the drive is up to speed and ready to accept a 
command. 


DWE is the drive write fault bit. When there is an error, this bit 
is not changed until the Status register is read by the Host, at 
which time the bit again indicates the current write fault status. 


DSC is the drive seek complete bit. This bit is active when the 
disk drive heads are settled over a track. When there is an 
error, this bit is not changed until the Status register is read by 
the Host, at which time the bit again indicates the current seek 
complete status. 


DRQ is the data request bit, which indicates that the drive is 
ready for transfer of a word or byte of data between the Host and 
the Data register. 


CORR is the corrected data bit, which is active when a 
correctable data error has been encountered and the data has 
been corrected. This condition will not terminate a multi-sector 
read operation. 


IDX is the index bit which is active once per disk revolution. 
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ERR is the error bit, which indicates that the previous 
command ended in some type of error. The other bits in the 
Status register, and the bits in the Error register will have 
additional information as to the cause of the error. 


12.10 Command Register 

-HOST CSO, address 7, Write only 
The eight bit code written to this register passes the drive the 
command from the Host. Command execution begins 
immediately after this register is written. A list of executable 


commands with the command codes and necessary parameters 
for each command follows (see next page). 
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where: 


L is the long bit, if L=1, R/W long commands are executed, if 
L=0, normal R/W commands are performed. 


R is the retry bit; if R= 0, retries are enabled, if R= 1, retries are 
disabled. Retries that may be enabled/disabled are those on 
ECC and data errors. When retries are disabled at the start of a 
command, they are always automatically enabled at the end of 
the command. 
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SC is the sector count register. 

SN is the sector number register. 

CY is the cylinder registers. 

SDH is the drive/head register. 

Y means the register contains a valid parameter for this 
command. For the drive/head register, y means that both the 


drive and head parameters are used. 


N means the register does not contain a valid parameter for this 
command. 


D means only the drive parameter is valid and not the head 
parameter. 


X = don't care. 


For the command decode, the "1's" and "0's" are important. 
Failure to comply will result in an Aborted Command response 


or misinterpretation of the command. 
12.11 Alternate Status Register 


-HOST CS1, address 6, Read only 


This register contains the same information as the Status 
register in the Task File. The only difference being that reading 
this register does not imply interrupt acknowledge to reset a 
pending interrupt. 
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See the description of the Status register for definitions of the 
bits in this register. 


12.12 Digital Output Register 
-HOST CS1, address 6, Write only 


This register contains two control bits as follows: 


(7 | be | bs | ba | bs | be | bt | bo | 
p- | - | - | - | ~ |sast} -en] ~ | 


where: 


—IEN is the enable bit for this disk drive interrupt to the Host. 
When this bit is active, and the drive is selected, the Host 
interrupt, HOST IRQ14, is enabled, through a tri-state buffer, to 
the Host. When this bit is inactive, or the drive is not selected 
the HOST IRQ14 pin will be in a high impedance state, 
regardless of the presence or absence of a pending interrupt. 


SRST is the Host software reset bit. The drive is held reset 
when this bit is active, and enabled when this bit is inactive. If 
two drives are daisy chained on the interface, this bit will reset 


both drives simultaneously. 


-- these bits are not used. 
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12.13 Drive Address Register 


-HOST CS1, address 7, Read only 
This register loops back the drive select and head select 


addresses of the currently selected drive. The bits in this 
register are as follows: 


| b7 | bo | bs | bs | bs | be | bt | bo 


where: 






RSVD is reserved and undriven by the drive. When the Host 
reads the drive address register, this bit must be in a high 
impedance state. 


—WTG is the write gate bit, which is active when writing to the 
disk drive is in progress. 


-HS3 through —HS0 are the one's complement of the binary 
coded address of the currently selected head. For example, if 
HS3 through HS0O are 1 1 00, respectively, head 3 is selected. - 
HS3 is the most significant bit. 


-DS1 is the drive select bit for drive 1, and should be active 
when drive 1 is selected and active. 


-DS0 is the drive select bit for drive 0, and should be active 
when drive 0 is selected and active. 


It is important to note that Bit 7 is not driven for compatibility 
with the floppy drive address space. 


Note: If your system is different, you may have to drive this bit 
when this register is read. 
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13.0 Command Description 


All commands are decoded from the COMMAND Register. The 
Host interface shall be programmed by the Host computer to 
perform commands and will return status to the Host at 
command completion. When two drives are daisy chained on the 
interface, commands are written in parallel to both drives, only 
the selected drive will execute the command, except for the 
diagnostic command. In that case, both drives execute the 
command and the slave drive reports its status to the master via 
the -HOST PDIAG signal. 


Drives are selected by the DRV bit in the drive/head register and 
by ajumper, C/D, on the drive designating it as either a master 
or slave. See the section on Customer Options. When the DRV 
bit is reset, the master drive is selected. When the DRV bit is 
set, the slave drive is selected. When drives are daisy chained, 
one must be jumpered as the master and one as the slave. When 
a single drive is attached to the interface, it must be jumpered 
as the master. Throughout this document, drive selection always 
refers to the state of the DRV bit, and position of the 
master/slave jumper. 


To issue a command, load the pertinent registers in the Task 
File, activate the interrupt enable bit, -IEN in the digital output 
register, and then write the command code to the command 
register. Execution begins as soon as the command register is 
written. Also see the section on retries. 
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13.1 Recalibrate —- 10 


This command will move the R/W heads from anywhere on the 
disk to cylinder 0. Upon receipt of the command,the drive sets 
BSY and executes a seek to cylinder 0. The drive then waits for 
the seek to complete before updating status, resetting BSY and 
generating an interrupt. If the drive cannot reach cylinder 0, the 
error bit is set in the Status register and the track 0 bit set in 
the Error register. An aborted command response will be given if 
the drive is not spinning or is not on track. Upon successful 
completion of the command, the Task File registers will be as 
follows: 


Error Register| 00 


Sector Count Unchanged 


Sector Number Unchanged 


CylinderLow | oo 
Cylinder High | 00” 


SDH Unchanged 
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13.2 Read Sector(s) - 2X 


This command will read from 1 to 256 sectors as specified in the 
Task File (sector count equal to 0 requests 256 sectors), 
beginning at the specified sector. As soon as the Command 
register is written, the drive sets the BSY bit and begins 
execution of the command. An aborted command is set if bits 2 
& 3 are not equal to zero. An ID not found error is returned if 
incorrect Task File parameters are passed. If the drive is not 
already on the desired track, an implied seek is performed. 
Once at the desired track, the drive begins searching for the 
appropriate ID field. If the ID is read correctly, the data field is 
read into the sector buffer, error bits are set if an error was 
encountered, the DRQ bit is set and an interrupt is generated. 
The DRQ bit is always set regardless of presence or absence of 
an error condition at the end of the sector. Upon command 
completion, the Task File registers contain the cylinder, head, 
and sector number of the last sector read. The sector count is 
zero after successful execution of the command. 


Multiple sector reads set DRQ and generate an interrupt when 
the sector buffer is filled at the completion of each sector, and 
the drive is ready for the data to be read by the Host. DRQ is 
reset and BSY is set immediately when the Host empties the 
sector buffer. If an error occurs during a multiple sector read, 
the read will terminate at the sector where the error occurs. The 
Task File registers will contain the cylinder, head, and sector 
number of the sector where the error occurs. The Host may then 
read the Task File to determine what error has occurred, and on 
which sector. If the error was either a correctable data error or 
an non-correctable data error, the flawed data is loaded into the 
sector buffer. 


The read does not terminate if the error was a correctable data 


error. Ifno error is detected, the cylinder, head, and sector 
registers are updated to point to the next sequential sector. 
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A Read Long may be executed by setting the long bit in 
command code. The Read Long command returns the data and 
the ECC bytes contained in the data field of the desired sector. 
During a Read Long, the drive does not check the ECC bytes to 
determine there has been any type of data error. Data bytes are 
16 bit transfers and ECC bytes are eight bit transfers. Seven 
ECC bytes are transferred. 


13.3 Write Sector(s) - 3X 


This command will write from 1 to 256 sectors as specified in the 
Task File (sector count equal to 0 requests 256 sectors), 
beginning at the specified sector. As soon as the Command 
register is written, the drive waits for the Host to fill the sector 
buffer with the data to be written. No interrupt is generated to 
start the first buffer fill operation. Once the buffer is full, the 
drive sets BSY and begins command execution. If bits 2 & 3 are 
on, the command terminates with aborted command. An ID not 
found error is returned if incorrect task file parameters are 
passed. Ifthe drive is not already on the desired track, an 
implied seek is performed. Once at the desired track, the drive 
begins searching for the appropriate ID field. If the ID is read 
correctly, the data loaded in the buffer is written to the data 
field of the sector, followed by the ECC bytes. Upon command 
completion, the Task File registers contain the cylinder, head, 
and sector number of the last sector read. The sector count is 
zero after successful execution of the command. 
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Multiple sector writes set DRQ and generate an interrupt 

each time the buffer is ready to be filled. DRQ is reset and BSY 
is set immediately when the Host fills the sector buffer. If an 
error occurs during a multiple sector write, it will terminate at 
the sector where the error occurs. The Task File indicates the 
location of the sector where the error occurred. The Host may 
then read the Task File to determine what error has occurred, 
and on which sector. If no error is detected, the cylinder, head, 
and sector registers are updated to point at the next sequential 
sector. 


A Write Long may be executed by setting the long bit in the 
command code. The Write Long command writes the data and 
the ECC bytes directly from the sector buffer; the drive will not 
generate the ECC bytes itself for the Write Long command. 
Data byte transfers are 16 bits, ECC bytes are 8 bit transfers. 
Seven bytes must be transferred even though only the first four 
are used for ECC. 


13.4 Verify Sector(s) — 4X 


This command works exactly the same as the Read Sectors 
command except that no data is transferred. Up to 256 sectors 
will be read into the sector buffer and ECC bytes verified, 
beginning at the location specified by the task file. When each 
sector has been verified, the Task File is updated but no data 
request or interrupt is set to indicate that the sector has been 
verified. When all sectors have been verified, an interrupt is 
generated to indicate that all sectors have been transferred. A 
value of 00 in the sector count register indicates that 256 sectors 
are to be verified. Read look aheads are enabled for this 
command. 
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13.5 Format Track — 50 


This command formats the track specified in the Task File. As 
soon as the Command register is written, the drive waits for the 
Host to fill the buffer with the format data. When the buffer is 
full, the drive resets DRQ, sets BSY and begins 

command execution. An aborted command is set if any bits 0-3 
are "1". If the drive is not already on the desired track, an 
implied seek is performed. Once at the desired track, formatting 
begins using the data in the sector buffer. A sector my be 
formatted Good/Bad or an alternate Assigned/Unassigned. At 
the completion of the track, the drive resets BSY and generates 
an interrupt. 


The 512 bytes of Format Track data in the sector buffer must 
conform to a specified format. There must be one word, (2 bytes), 
for each sector to be formatted. The words must be contiguous 
and begin at the start of the sector. Unlike some drives where 
the order of the words is used to determine the interleave, the 
order of the words is not significant because the drive’s 
interleave cannot be changed. The most significant byte of each 
word must contain a sector number to be formatted. The least 
significant byte must contain a descriptor byte that indicates 
what is to be done to that sector. There are four possible 
descriptor bytes: 


. 00h = format sector good 

. 80h = format sector bad 

. 40h = assign this sector to an alternate location 
20h = unassign the alternate location for this sector 


OD eS 
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The drive will return an ID not found under the following 
conditions: 


1. If there is a missing word for any sector along the track. 

2. If the words are not contiguous from the start of the 
sector. 

3. If there is more than one word (two bytes) of data per 
sector. 

4. If the task file calls for an illegal cylinder and/or head. 


A utility program to handle defective sectors should provide a 
method to identify the defective sectors. The program should 
build a 512 byte block with a word for each sector for the track. 
These words must be in the first contiguous words of the block. 
The most significant byte of each word should contain a sector 
number to be formatted. Then the defective sector’s descriptor 
byte should be set to either 80h or 40h depending on whether or 
not the sector is to be formatted bad or reassigned. 


All the remaining sectors should have a descriptor byte of 00, 
which says to format those sectors good. Once the Format Track 
data block is created, the Format command can be executed by 
interfacing it through the BIOS. 


It is important to remember that all data on the track will be 
lost. The drive formats according to the logical tracks defined by 
either the power on reset default or by the values issued by the 
last Initialize Drive Parameters command. 
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13.6 Seek — 70 


This command initiates a seek to the track and selects the head 
specified in the Task File. The drive need not be formatted for a 
seek to execute properly. When the command is issued, the drive 
sets BSY in the Status register, initiates the seek, resets BSY, 
and generates an interrupt. Only the Cylinder register is valid 
for this command. The drive does not wait for the seek to 
complete before returning the interrupt. Seek complete will be 
set upon completion of the command. If anew command is 
issued to a drive while a seek is being executed, the drive will 
wait, with BSY active, for the seek to complete before executing 
the new command. No checks are made on the validity of the 
sector number or head value in the task file. 


If the cylinder value is incorrect, the seek is not performed and 
seek complete is set. The error bit is not set. 


13.7 Execute Drive Diagnostic — 90 


This command performs the internal diagnostic tests 
implemented by the drive. The diagnostic tests shall only be 
executed upon receipt of this command. The drive sets BSY 
immediately upon receipt of the command. If the drive is a 
master, C/D jumpered, the drive performs the diagnostic tests 
and saves the results. It then checks to see if a slave drive is 
present and waits up to 5 seconds for the slave to complete its 
diagnostics. If the slave successfully completes its diagnostics, it 
asserts -HOST PDIAG. If unsuccessful, it sets its Error register 
as described below. The master drive resets BSY, and generates 
an interrupt. The value in the Error register should be viewed 
as a unique 8 bit code and not as the single bit flags defined 
previously. The interface registers are set to initial values 
except for the Error register if an error has occured. 
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The table below details the codes in the Error register and a 
corresponding explanation: 





01 no error detected 
03 sector buffer error 
8x slave drive failed (see note below) 






Note: If the slave frive fails diagnostics, the master drive shall “OR” 80 
Hex with its own status and load that code into the Error register. If 
the slave drive passes diagnostics or there is no slave drive connected, 
the master drive shall reset bit 7 of the Error Register in the Task File 
to zero. 


Additional codes may be implemented at the manufacturer's 
option. 


13.8 Initialize Drive Parameters - 91 


This command enables the Host to set the head switch and 
cylinder increment points for multiple sector operations. The 
sector, head, and cylinder values in the Task File are not 
checked for validity by this command. Therefore, if they are 
invalid, no error will be reported until an illegal access is made 
by some other command. Cylinder and head increments on 
subsequent commands will occur after access of the maximum 
sector and maximum head specified by this command. If the 
initialize drive parameters command is not issued at power up, 
the drive will default to 33 sectors per track, 8 heads, and 776 
cylinders. Upon receipt of the command, the drive sets BSY, 
saves the parameters, resets BSY, and generates an interrupt. 
To specify maximum heads, write 1 less than the maximum, e.g. 
write 4 for a 5 head drive. To specify maximum sectors specify 
the actual number of sectors, e.g. 33 for a maximum of 33 
sectors/track. 
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In order to facilitate the CP3104's use in systems for which there 
may be no exact device type, this command has been changed 
slightly. Any head and sector value will be accepted. From 
these two values, the drive will compute the maximum cylinder. 
This is done by dividing the product of the number of heads and 
the number of sectors into 204,864 (the total number of sectors 
in the drive). One must be careful when selecting a device type 
so that the total number of cylinders expected by the particular 
device type does not exceed that possible by the drive. This 
could cause errors at boot time. Where possible, it is 
recommended that the device type that matches the CP3104's 
native parameters is used or put into the BIOS. 


13.9 Read Multiple Command - C4 


The Read Multiple command is identical to the read sectors 
operation but several sectors are transferred the the Host as a 
block without intervening interrupts, only requiring DRQ 
qualification of the transfer at the start of the block count on 
each sector. Long transfers are not permitted. The block count, 
which is the number of sectors to be transferred as a block, is 
programmed by the Set Multiple Mode command which must be 
executed prior to the Read Multiple command. When the Read 
Multiple command is issued, the Sector count Register will 
contain the number of sectors (not the number of blocks or the 
block count) requested. If this sector count is not evenly 
divisible by the block count, as many full blocks as possible are 
transferred, followed by a final, partial block transfer. The 
partial block transfer will be for N sectors, where 


N = (sector count) modulo (block count). 
If the Read Multiple command is attempted before the Set 
Multiple mode command has been executed or when Read 


Multiple commands are disabled, the Read Multiple operation 
will be rejected with an aborted command error. 
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Disk errors encountered during Read Multiple commands will be 
reported at the beginning of the block or partial block transfer, 
but DRQ will still be set and the transfer will take place as it 
normally would, including transfer of corrupt data, if any. 
Subsequent blocks or partial blocks will only be transferred if 
the error was a correctable data error. All other errors will 
cause the command to stop after transfer of the block which 
contained the error. Interrupts are generated when DRQ is set 
at the beginning of each block or partial block. Read look aheads 
are not active for this command. 


13.10 Write Multiple Command - C5 


The Write Multiple command performs similarly to the Write 
sectors command except that the controller sets BSY 
immediately upon receipt of the command, data transfers are 
multiple sector blocks, and the long bit is not valid. Several 
sectors are transferred to the Host as a block without 
intervening interrupts, only requiring DRQ qualification of the 
transfer at the start of the block, not on each sector. There is no 
IRQ prior to the first block transfer. The block count, which is 
the number of sectors to be transferred as block, is programmed 
by the Set Multiple Mode command, which must be executed 
prior to the Write Multiple command. When the Write Multiple 
command is issued, the Sector count Register will contain the 
number of sectors (not the number of blocks or the block count) 
requested. If this sector count is not evenly divisible by the 
block count, as many full blocks as possible are transferred, 
followed by a final, partial block transfer. The partial block 
transfer will be for N sectors, where 


N = (sector count) modulo (block count). 


If the Write Multiple command is attempted before the Set 
Multiple Mode command has been executed or when Write 
Multiple commands are disabled, the Write Multiple operation 
will be rejected with an aborted command error. 


All disk errors encountered during Write Multiple commands 
will be reported after the attempted disk write of the block or 
partial block is transferred. The write operation will end with 
the sector in error, even if it was in the middle of a block. 
Subsequent blocks will not be transferred in the event of an 
error. Interrupts are generated when DRQ is set at the 
beginning of each block or partial block. 


13.11 Set Multiple Mode - C6 


This command enables the controller to perform Read and 
Write Multiple operations and establishes the block count for 
these commands. Prior to command issuance, the Sector Count 
Register should be loaded with the number of sectors per block. 
Block sizes supported are 1, 2, 4, 8, 16, 32 and 64. Upon receipt 
of the command, the controller sets BSY and looks at the Sector 
Count register contents. If the register contents are valid and 
supported block count is supplied, that value is loaded for all 
subsequent Read and Write Multiple commands and execution 
of these commands is enabled. Any unsupported block count in 
the register will result in an aborted command error and Read 
and Write Multiple commands being disabled. If the sector 
count register contains 0 when the command is issued, Read and 
Write Multiple commands will be disabled. Once the 
appropriate action has been taken, the controller resets BSY and 
generates an interrupt. At power up, or after a hardware or 
software reset, the default mode is to have Read and Write 
Multiple disabled. 


13.12 Read Buffer - E4 


The Read Buffer command allows the Host to read the current 
contents of the drive's sector buffer. Only the Command resister 
is valid for this command. When this command is issued, the 
drive will set BSY, set up the sector buffer for a read operation, 
set DRQ, reset BSY, and generate an interrupt. The Host may 
then read up to 512 bytes of data from the buffer. 
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13.13 Write Buffer — E8 


The Write Buffer command allows the Host to overwrite the 
contents of the drive's sector buffer with any data pattern 
desired. Only the Command register is valid for this command. 
When this command is issued the drive hardware sets up the 
sector buffer for a write operation and sets DRQ. The Host may 
then write up to 512 bytes of data to the buffer. 


13.14 Identify Drive —- EC 


The Identify command allows the Host to receive parameter 
information from the drive. When the command is issued, the 
drive sets BSY, stores the required parameter information in the 
sector buffer, sets the DRQ bit, and generates an interrupt. The 
Host may then read the information out of the sector buffer. 

The parameter words in the buffer are arranged as follows; all 
numbers are given in hexadecimal format right justified, all 
reserved bits or words are zeroes. 


Word 00 — A constant 0A5Ah 

Word 01 — Number of fixed cylinders 

Word 02 _ Number of removable cylinders 

Word 03 — Number of heads 

Word 04 _ Number of unformatted 
bytes/physical track 

Word 05 - Number of unformatted 
bytes/sector. 

Word 06 - Number of physical sectors/track 

Word 07 = Number of bytes in the inter sector 
gaps 

Word 08 — Number of bytes in the sync fields 

Word 09 _ 0000h 

Word 10-19 — Serial number 

Word 20 — Controller type 


0003h dual ported multiple sector 
buffer with look ahead read. 
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Word 21 Controller buffer size in 512 byte 


increments 

Word 22 _ Number of ECC bytes passed on 
Read/WriteLong commands 

Word 23-26 — Controller firmware revision 

Word 27-46 — Model number 

Word 47 — Number of sectors/nterrupt (0 = does not 
support >1) 

Word 48 — Double word transfer flag (0 = not 
capable, 1 = capable) 

Word 49 — Assign Alternate (0 = not capable, 1 
= capable) (See Format Description) 

Word 50-255 — Reserved 


13.15 Set Buffer Mode Command - EF 


This command allows enabling or disabling of the read look- 
ahead feature. Prior to command issuance, the Write 
Precompensation register should be loaded with either AAh, to 
enable, or 55h to disable read look ahead operation. Upon 
receipt of the command the controller sets BSY and looks at the 
Write Precompensation register contents. If the register 
contents are either AAh or 55h, the appropriate mode is 
selected. Any other value in the register will result in an 
aborted command. At command completion, the controller 
resets BSY and generates an interrupt. At power up, or after a 
software or hardware reset, the default mode is read look ahead 
enabled. 
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14.0 Operations Description 


The following paragraphs describe operations that span several 
commands or are not covered sufficiently in the preceding 
paragraphs. 


14.1 Reset 


A RESET condition will set the drive busy, allowing the drive to 
perform the proper initialization required for normal operation. 


A RESET condition can be generated in three ways. There are 
two hardware resets, one from the Host (- HOST RESET) and 
one from the drive power sense circuitry. These are set high 
when the system and the drive respectively acknowledge good 
power. The other reset is software generated. The Host can 
write to the Digital Output register and set the reset bit. This 
Host software reset condition will persist until a zero is written 
to the reset bit. 


Once the reset has been removed and the drive has been re- 
enabled, with BSY still active, the drive will perform any 
necessary hardware initialization, clear any previously 
programmed drive parameters and revert to the defaults, load 
the Task File registers with their initial values, and then reset 
BSY. Nointerrupt is generated when initialization is 
complete. 
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The initial values (hex) for the Task File registers are as follows: 


Sector Count 
a 
| cytindertow | 00 
| cylinder High | 00 
[ Drive/tiead Register | 00 


14.2 Busy Operation 











“BSY” is set in a number of ways. A RESET condition described 
above is one way. Another method occurs when the Host issues a 
command. For a non Write type command, the register is clocked 
BSY on the Host write of the Command register. The disk 

controller and microprocessor prepare the data to return and set 
the drive not BSY to allow the Host access of the data requested. 


On a Write type command, the command is issued, setting the 
1016 enable and Data Request, but BSY is not set until the data 
to be written is putinto the RAM buffer. This is accomplished 
by setting BSY on the condition of the buffer becoming full in 
write. Write type commands include Write Sector (s), Format, 
and Write Sector Buffer. A Write Multiple command will set 
BSY immediately. Sometime later BSY will drop and Data 
Request will be set. 
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In addition, the drive microprocessor has the ability to set/reset 
BSY. This is the only way that BSY can be cleared. This means 
that the only way a drive can respond properly to a command is 
for the drive microprocessor to be active. When BUSY is 
active, the drive has read and write access to the Task File 
registers, the Host can only read the Status register and 
Alternate Status register of the Task File. Any attempted Host 
read of a Task File register while BSY is active, results in 
reading the Status register. 


When BSY is inactive, the Host has read and write access to all 
Task File registers. 


14.3 Retries 


Data Retry Algorithm 


When an ECC error is detected in the data field during a read 
operation, the following retry algorithm is used: 


Step 1. read retry 

Step 2. read retry 

Step 3. read retry 

Step 4. apply ECC to step 3 

Step 5. read retry with +65 micro inch offset 
Step 6. apply ECC to step 5 

Step 7. read retry 

Step 8. apply ECC to step 7 

Step 9. read retry with 65 micro inch offset 
Step 10. apply ECC to step 9 

Step 11. read retry 

Step 12. read retry 

Step 13. read retry 

Step 14. read retry 

Step 15. read retry 

Step 16. read retry 
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In the event of a hard error, steps 1-16 are repeated eight times 
for a total of 128 retries. Allowing 17 msec for each read retry 
and 75 msec for each ECC correction, this is a total time of 4.0 
seconds (17*12*8/1000 + 75*4*8/1000) to return a non- 
recoverable error condition to the Host. With the exception of 
disabling retries (i.e. retry count = 0) the retry count of 128 is 
currently not changeable. 


If there is a successful read or ECC in any of the above steps, the 
retry process is aborted and the data is returned to the Host. 
When the R/W heads are switched or a seek is completed, the 
drive will attempt an offtrack read when less than 200 micro 
inches from the center of the track. If this attempt is successful, 
17 msecs of latency is saved and seek performance of the drive 
will exceed the specification. When this attempt is not 
successful, the drive will read the sector on the next pass as ina 
normal read operation (100 micro inch) and the seek 
specification is met. 


Header Retry Algorithm 


When an ECC error is detected while reading the header field, 
20 read retries are attempted before a header error is returned 
to the Host. Ifa header is successfully read before the 20 retries 
are completed, the header retry counter is reset and the data 
field is processed. For a hard error in the header field, the total 
amount of time for 20 retries is 340 msec (17*20/1000). Header 
retries can not be disabled from the interface, nor can the header 
retry count be changed. 


Revision 1.3 -57- 


14.4 1:1 Operations 


Previous Conner AT interface drives were 3:1 interleave. The 
CP3104, while compatible, requires some explanation of the 
idiosyncracies of 1:1 operations. For write operations, sequential 
single sector operations will be slower due to missing the 
interleave. Multiple block operations will be faster because after 
receiving all blocks except the last, the next block is requested 
while the data is being written to the disk. After the last block 
is received, the drive goes BUSY until it is done processing all 
the data. In case of error, the Task File registers will point to 
the actual failing block. 


The 1:1 interleave and the 32kb buffer are combined to provide 
read look ahead capability. For this drive, with read look aheads 
active, any read will cause the drive to read a minimum of 64 
contiguous sectors of data. All subsequent read operations will 
test if the data is already in the buffer before going to the disk. 
If any other command other than a read is issued following the 
sie read, the buffer will be purged before the operation takes 
place. 


It is important to remember that the overall throughput of the 
drive is a combination of the drive's ability to provide data and 
the Host computers ability to take it. For those customers 
requiring a faster transfer rate than the standard 3.75MB 
provided, it is possible to provide a 4.75MB transfer rate. 


14.5 AC Hysterisis 


All inputs have AC hysterisis so that at signal rise/fall times of 
25ns, the drive will have .55 volt hysterisis and at rise/fall time 
of 10ns, the hysterisis will be .95 volts. 
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14.6 Formatting 


Conner drives are different from previous ST506 type drives in 
that they do not require a low level format. This low level 
format is done in the factory as part of the extended burn in 
process and it is not possible to do via the Host interface. To put 
a drive on a system, it is only necessary to FDISK and then do a 
system FORMAT. 
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15.0 Error Reporting 


In general, errors are detected in the following fashion by the 
drive microprocessor. At the start of the execution of the 
command, the command register is checked for conditions that 
would lead to an aborted command. Then the operation is 
attempted. The errors that are valid for each command are 
summarized below. Any subsequent error terminates the 
command at the point that it is discovered. 





Error Type Valid 
ees ABRT, TKO, DRDY, DWF, 
a DSC, ERR 


BBK, UNC, IDNF, ABRT, DRDY, 
DWF, DSC, CORR, ERR 


BBK, IDNF, ABRT, DRDY, 
Reed Long DWF, DSC, ERR 


Write Sector BBK, IDNF, ABRT, DRDY, 
DWF, DSC, ERR 
Write Long BBK, IDNF, ABRT, DRDY, 
DWF, DSC, ERR 
; BBK, UNC, IDNF, ABRT, DRDY, 
iat) DWF, DSC, CORR, ERR 


IDNF, ABRT, DRDY, DWF, 
DSC, ERR 


IDNF, ABRT, DRDY, DWF, 
DSC, ERR 
















Read Sector 







Format Track 







Seek 









Drive Diagnostics ABRT, ERR 


BBK, UNC, IDNF, ABRT, DRDY, 
Head MUaUpIS DWF, DSC, CORR, ERR 


Write Multiple BBK, IDNF, ABRT, DRDY, 
DWF, DSC, ERR 


Set Buffer Mode ABRT, ERR 





















Invalid Command Code ABRT, ERR 
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where: 


BBK 
UNC 
IDNF 
ABRT 
TKO 
DRDY 


DSC 
CORR 
ERR 


is bad block detected 

is non correctable data error 

is requested ID not found 

is aborted command error 

is track 0 not found error 

is disk Drive not ready detected 

is disk Drive write fault detected 

is disk Drive seek complete not detected 
is corrected data error 

is the error bit in the Status register 
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Appendix A: Evaluation Adapter Board 
Introduction 


In order to facilitate evaluation and aid those manufacturers 
interested in quickly getting the CP3104 drive running, Conner 
Peripherals has developed an adapter board to be used in 
conjunction with the drive on an AT or equivalent system. The 
drive requires no special driver program as it works with the 
existing AT BIOS or equivalent. It is hoped that the interface 
will be incorporated into the motherboard of the AT device or on 
some other multi function adapter. The artwork and Bill of 
Materials are available upon request. 


Description 


The AT Task File Interface is a set of registers that allows 
execution of a set of commands via the Host Computer BIOS. 
The CP3104 drive implements the Task File on the drive. The 
adapter board buffers the drive from the Host and does the 
address decode. 


The adapter card decodes the Host I/O addresses IFO 1F7 and 
3F6 3F7. These addresses are set aside for disk drive use in the 
AT BIOS. The drive will respond to the commands issued by the 
BIOS. 


The floppy drive also responds to address 3F7, bit 7. The 
adapter card does not drive this bit. 
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Requirements 


The following is required to run the drive: 


Host adapter board 
40 pin flat cable 


Installation of the Drive and Adapter Board 


1. 


Pick a device type that is equal to or less than the 
CP3104 in capacity and update the PC's CMOS. 


Remove power to the computer 


If another hard disk controller is installed, it is 

necessary to prevent it from responding the addresses 
1F07h and 3F67h. It is also necessary to ensure that the 
controller is electrically disconnected or tri-stated from 
IRQ14 of the motherboard bus. This may be done either 
by removing the board, by electrically disconnecting the 
signals from the interface, or by setting the jumpers of the 
board to disable the hard disk controller. 


Insert the board into any available card slot. 
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5. Configure the Host adaptor for the correct 
configuration of your computer BIOS. 


Never installed 
| e2 Always in 
Never installed 


Note: E3 and EA are located in a straight line with a pin 
between them, as shown below. Jumper in refers to the pin 
jumpered to the center pin. 


K3 H4 
0 oO O 







6. Connect power to the CP3104 


7. Run the DOS FDISK program (or equivalent) to 
establish DOS partitions. 


Note: DOS 3.3 and below have limitations of 32 megabytes per 
volume unless a software utility is used to overcome this. 


8. Run the DOS FORMAT program by typing "Format C:/S". 
The volume may be named with the addition of the "/V". 
The format will be completed and the system transferred 
if the "/S" option was used. The system will ask for a 
volume name if the "/V" option is used. 


9. Files can then be copied to the C: drive from the 
floppy. 


10. When the system is rebooted, the system shouid boot 
from the hard drive (drive C:) if the floppy is removed. 
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- HOST CSO 
- HOST CS! 


- HOST SLV ACT 


- HOST PDIAG 


- HOST IOR 

- HOST Kw 
+HOST ALE 

- HOST RESET 
+ HOST A2 
+HOST At 
+HOST AO 


- HOST SLWACT 


+ HOST FRO14 


- HOST 1016 
+ HOST DATA 15 





2. AT Adapter Card Layout 


Figure A 
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System Board I/O 


System Board I/O 


Pin Signal 





Pin Signal 





Pin Signal Pin Signal 
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Problems 


If at power on, the drives spins up but is ignored by the system 
(indicated by the system taking a long time to boot) it is possible 
the IRQ14 is not becoming active. Check to make sure that the 
interrupt is isolated electrically from the original hard disk 
controller's IRQ14. 


If at power on, the drive does not ever spin up or does not spin 
up until after the computer completes power on, it is possible 
that RESET is either continually active or is electrically 
connected to some other signal. 


If when reading a directory, it is inaccurate or does not change, 
it is possible that the adapter board is connected to the bit 7 
when address 3F7 is read. 


If the computer completes its power on sequence before the drive 
is up completely and subsequently gets a 17xx error of some 
sort, and if a subsequent warm boot is successful, it is possible 
the BIOS is expecting a different status at power on before the 
system is ready. Either delay the power on sequence or change 
the BIOS to expect a 00 status before the drive become ready. 


NON SYSTEM DISK OR DISK ERROR. This could occur if no 
partition was made active by FDISK. 
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